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Communicating Data Using an HTTP Client 

TECHNICAL FIELD 

This invention relates to communicating data using an HTTP client. 

BACKGROUND 

The Hypertext Transfer Protocol ("HTTP") is a protocol defined by the Internet 
Engineering Task Force ("IETF") for transmitting data over a network, such as the Internet. 
Computer programs, such as web browsers, that communicate data by the hypertext transfer 
protocol ("HTTP") are known as HTTP clients. The HTTP clients send data to the server, 
which may include a request for data firom the server over the network. In response, the 
server may send data by HTTP to the client. HTTP clients may also send additional data to 
the server using either a "POST" or a "GET" method of the HTTP protocol. 

An HTTP client may invoke another computer executable to enhance the cUent's 
functionality. For example, the HTTP client may call on a separate executable to display a 
certain file format, such as a portable document format ("PDF") file. The computer 
executable may be a separate stand-alone computer application, a dynamically linked library 
("DLL"), or a helper program or plugm written for the HTTP client. The HTTP client may be 
linked to the executable through the operating system, an application program interface 
("APr') of the HTTP client, or through a mime-type table witiiin the HTTP cHent associating 
file formats with computer executables. 

SUMMARY 

In general, one aspect of the invention relates to an apparatus that includes a 
computer executable for processing a file of a first file type, and a Hypertext Transfer 
Protocol ("HTTP") client that receives files of the first type and a second type fi-om a 
network. The HTTP client causes the computer executable to process files of the first type. 
The computer executable includes a first module that determines whether the file includes a 
first content type and performs a first function if the file includes the first content type. The 
computer executable also includes a second module that determines whether the file includes 
a second content type and performs a second function different from the first function if the 
file includes the second content type. 
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Embodiments of the invention may include one or more of the following features. 
The first content type includes a set of instructions and the first module executes the 
instructions. The apparatus is associated with a computer processor and the computer 
executable further comprises an extraction module, the instructions causing the extraction 
5 module to extract information from the computer. The computer executable further 

comprises a third module for transmitting the extracted information by generating a HTTP 
request containing the information and sending the HTTP request over the network. The 
extracted information includes habitat information, such as a machine ED, a storage ID, an 
Ethernet address, or a processor ID. The instructions in the first content type cause the fn-st 
10 module to uistall computer software on a computer associated with the apparatus. The 

computer software is an updated version of the computer executable for processing a file. 
The computer executable fijrther comprising an HTTP module that generates a hypertext 
transfer protocol method, such as a PUT or a GET, for sending the extracted mformation over 
a network. 

^5 At least one of the first and second functions includes displaying, uncompressing, or 

storing at least a portion of the information contained within the file. 

In general, a second aspect of the invention relates to a method that includes a HTTP 
client receivmg a file and information about the type of the file, the HTTP client determining 
an computer executable associated with the file based on the information about the type of 

20 the file, the HTTP client causing the computer executable to process the file, the computer 

executable determining whether the file includes a first content type, the computer executable 
performing a first fimction if the file includes the first content type; and the computer 
executable determining whether the file includes a second content type, the computer 
executable performing a second function different from the fu-st function if the file includes 

25 the second content type. 

Embodiments of the second aspect of the invention may include one or more of the 
following features. The computer executable generates a HTTP request containing 
information and sends the information by sending the HTTP request over a network. The 
first content type includes a set of instructions and the first function includes executing the 

30 instructions. The method is associated v^th a computer and the instructions cause the 
extraction module to extract information from the computer. The extracted information 



-2- 



Docket No.: 07844-431001 



includes habitat information, such as a machine ID, a storage ID, and an Ethernet address. 
The instructions cause the computer executable to mstall computer software on the computer. 
For example, the installed computer software may be an updated version of the computer 
executable. The method ftirther includes generating a hypertext transfer protocol method, 
5 such as a PUT or a GET, for sending the extracted information over a network. 

At least one of the first and second fimctions includes uncompressing, displaying, or 
storing at least a portion of the information contained within the file. The file contains both 
the first content type and the second content type, the computer executable processing the file 
to perform both the first and the second fimction. 
10 The details of one or more embodiments of the invention are set forth in the accompa- 

nying drawings and the description below. Other features, objects, and advantages of the 
invention will be apparent from the description and drawings, and from the claims. 

DESCRIPTION OF DRAWINGS 

FIG. 1 is a block diagram of a system for commxmicating with a computer executable; 
FIG. 2 and 3 are flow charts of the process implemented by the system of FIG. 1; and 
FIGs. 4 A- 10 are screenshots of different user interface screens presented by the 
system of FIG. 1. 

DETAILED DESCRIPTION 

Referring to FIG. 1, a system for communicating with a computer executable includes 
20 client computers 4, 6 that communicate with a server 8 over a network 1 0. The client 

computers 4, 6 send information, for example using POST or GET methods 12 of HTTP, to 
the server 8. The server 8 sends information such as forms data format ("FDF") files 14 to 
the client computers 4 and 6. 

The server 8 includes a processor 16 and memory 24 for executing server programs 
25 1 8, such as a web server 20, stored within a storage subsystem 22, which is associated with 
the server 8. Storage subsystem 22 may include one or more storage devices such as a floppy 
disk, CDROM, hard disk, or a hard disk array. The web sender 20 includes an input interface 
26 for receiving information 12 from the client computers 4, 6 and an output interface 27 for 
sending information 14 to the client computers. The server programs 18 store data 28, such 



-3- 



Docket No. : 07844-43 1 00 1 

as a web site 30 that includes FDF files 32, licenses 34 and information 36 about client 
computers 4,6, within storage 22, 

The client computer 6 includes a processor 40 and memory 43 for executing client 
programs 42 stored within a storage subsystem 44 associated with the client computer 6. 
5 Storage subsystem 44 may include one or more storage devices such as a floppy disk, 

CDROM, hard disk or a disk array. Storage subsystem 44 is assigned a storage identifier 
("storage ID") 48 by an operating system of the client computer 6, The client programs 42 
include a web browser 49 that sends and receives information, such as files, via the network 
10. Storage 44 also contauas a helper computer executables 50, such as Adobe Acrobat™ by 

10 Adobe Systems Inc., which enhance the functionality of web browser 49. The client 
programs 42 store data 54, such as licenses 56, within storage 44. 

The web browser 49 maintains a collection of mime-type associations 52 relating 
different file types (also known as mime-types) with their corresponding computer 
applications for enhancing the fimctionality of the web browser 49. For example, the 

15 associations 52 relate FDF files 14 with Helper executable 50. Consequently, the web 

browser 49 causes Helper executable 50 to process any FDF files 14 that are received fi-om 
the network 10. 

The FDF files 14a, 14b, 14c contain data 60a, 60b, 60c. For example, FDF file 14a 
includes a set of instructions 62 directing Helper executable 50, for example, to extract the 
20 storage ID 48 and send it to the server 8, while FDF file 14c contains a compressed document 
61 in portable document format ("PDF"). On the other hand, FDF file 14b contains a license 
63 ("XML license") authorizing the client computer 6 to open the PDF document 61 
contained within the FDF file 14c. Each of the FDF files 14a, 14b, 14c contains a content list 
64a, 64b, 64c listing the content-types of the different kinds of data 60a, 60b and 60c in the 
25 file. For instance, the content list 64a for file 14a would be: 
histruction File 
the content list 64b for file 14b would be: 
License file 

while the content list 64c for the file 14c would be 
30 PDF file. 
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The content listing makes it easier for Helper executable 50 to determine what to do with the 
data. 

Helper executable 50 includes a display module 70 for uncompressing compressed 
files and displaying PDF documents, an instruction executor 72 for executing instructions 
5 stored within an FDF file, and an authorization module 74 for determining whether an XML 
license is required to display a PDF document. Executable 50 also includes an extraction 
module 76 for extracting information fi-om client computer 6 and an HTTP module 78 for 
sending the extracted information to the server 8 over the network 10 by generating and 
sending an HTTP post or get method 14 containing the extracted information. Thus, the 
10 system 2 allows the sever 8 to send information to Helper executable 50 as FDF files while 
alloying Executable 50 to send extracted information to the server as HTTP put or get 
methods. 

The extraction module 76 extracts such information as the storage ID and other 
information about client computer 6, collectively known as habitat or environment 

15 information. The extraction module 76 generates a machine ID for identifying the client 

computer 6 based on the habitat information. For example, the machine ID may be based on 
an identifier assigned to the processor 40 by its manufacturer, an Ethemet address of a 
network interface card associated with the client computer 6, or an identifier assigned to the 
client computer 6 by an operating system. 

20 Referring to FIG. 2, the process 1 00 for communicating information from server 8 to 

helper executable 50 v^U be described. The process 100 includes a web browser 49 
associating (102) the FDF file type or MIME-type with Helper executable 50. A MIME type 
is a Multipurpose Internet Mail Extensions type and is used to indicate the type of document 
being transmitted over the Intemet, for example, in an email message. The association may 

25 be performed, for example, as part of the installation of Helper executable 50 on the client 

computer 6 or as part of the installation of the web browser 49. When the user 15 types (104) 
the URL of a web page associated with the server 8, the web browser 49 loads (106) (i.e. the 
browser retrieves and displays the web page) the web page. The web page includes a link to 
a FDF file 14. The user 15 initiates the transmission of the web page to the cUent computer 6 

30 by clicking (1 08) on the link associated with the FDF file 14 causing the web browser 49 to 
send (1 1 0) a HTTP request for the FDF file to the server 8. The server 8 responds to the 
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request by sending (112) the FDF file along with information indicating the mime-type of the 
file to the browser 49. 

Upon receiving (1 14) the mime-type of the FDF file, the web browser 49 determines 
(116) that Helper executable 50 is associated with the FDF mime type based on the mime 
5 type associations 52. The web browser 49 checks (118) whether Helper executable 50 is 
open and opens (120) Executable 50 if it is not open. The web browser 50 sends (122) the 
FDF file to Executable 50, for example, using the Object Linked Embedding ("OLE") API 
by Microsoft Corporation. 

Executable 49 examines (124) the data 60a, 60b contained within the FDF file to 

10 determine the content type of the data. If the data 60a, 60b contains (126) instructions 62, the 
instruction executor 72 executes (128) the instructions 62, and if the data 60a, 60b contains 
(130) an XML license 63, Helper executable 50 saves the license 63 as data 54 within storage 
44. If the data contains a PDF document 61, the display module 70 checks (136) whether the 
PDF document 61 is compressed and uncompresses (138) it if it is compressed. The display 

15 module 70 then saves (140) and displays (142) the PDF document 61 . 

Referring to FIG. 3, the processing 200 performed on downloading the FDF file 
14C will be described. The authorization modxile 74 to determines (202) whether a license is 
required to display the PDF document 61 contained within the FDF file by examining the 
document. If a license is not required, the display module 70 displays (236) the file. 

20 Otherwise, if a license is required, the authorization module checks (206) whether data 54 
includes a valid license for the PDF document 61. If data 54 includes a valid license, the 
display module 70 displays (236) the file. Otherwise, the authorization module prompts 
(208) the user 15 to select whether or not to download the license. The authorization module 
then checks (210) whether the user 15 has selected to download the license. If the user 15 

25 has selected not to download a license, Executable 50 terminates the processing 200. 

Otherwise, if the user 15 has selected to download a license, the HTTP module 
generates (212) a HTTP post or get request informmg the server 8 that the user 15 has 
requested the dovraload of a license. The http module transmits (214) the put/get request to 
the server 8. The server 8 responds to the put/get request by sendmg (216) an FDF file 14a 

30 that contains instructions that cause the web browser to display that the server requires the 
client computer's Machine ID 46 and Storage ID 48 to issue a license. The instructions also 
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cause the browser 49 to prompt (218) the user 15 to authorize the sending of the IDs 46, 48. 
The user 1 5 authorizes (220) sending of the IDs 46, 48 on the web browser 49 allowing the 
extraction module 76 to extract (222) the IDs from cHent computer 6, for example, by 
querying the operating system associated with the client computer 6. The HTTP module 78 
5 then generates (224) a put/get request 12 containing the extracted information and sends 
(226) the put/get request 12 to the server 8, 

The server 8 sends (228) a web page to the browser 49 asking the user 15 for the user 
15's name and email address and prompting the user 15 to order a license. The user 15 
submits (230) the information required to order a license on the web browser causing the 
10 server 8 to send (232) the FDF file 14b containing the XML license 63 required to display 
the PDF document 61. The authorization module 74 extracts (234) and saves the license 63 
Mdthin data 54. The license 63 includes information about the machine ID 46 and the storage 
ID 48 of the client computer 6. The display module then displays (236) the PDF file 61 to 
the user 15. 

1 5 When the user 1 5 later tries to open the same PDF file 6 1 , the authorization module 

retrieves the license 63 from storage 44 and checks whether the license bears the same 
machine ID 46 and the storage ED 48 as the client computer 6. If the license is valid but does 
not have the same machine ID 46 and the storage ID 48 as the client computer 6, Executable 
50 prompts the user 15 to get a license for the computer before displaying the file. Thus the 

20 method of conununicating may be used to license PDF documents to client computers 6. The 
PDF documents may represent books, magazines, and so forth. 

Referring to FIG. 4A, when the user 15 types (102, FIG. 2) the URL of the web page 
302 associated vrith the server 8, the web browser 49 displays the web page 302 on a monitor 
associated v^th the client computer 6. The web page 302 includes instructions 304 on how to 

25 download electronic books contained within FDF files and a link 306 to the FDF file 14a. 
The user 15 downloads the FDF file 14a by clicking on the link 306 using a mouse pointer 
associated with the client computer 6, causing the web browser 49 to display the download 
screen 320, shown in FIG. 4B. The download screen 320 includes a graphical indicator 340 
which shows how much of the FDF file 14a has been downloaded along with details 342 

30 about the download process, such as the download transfer rate 342a, the location where the 
file is being downloaded to 342b, and an estimate of how much time 342c is left before the 
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file is fully loaded. The user 15 may cancel the download by clicking on the cancel button 
344. 

Referrring to FIG. 5A, once the file is downloaded, the Helper executable 50 displays 
a dialog for saving a PDF file 61 contained within the FDF file 14a, To save the file 61, the 
5 user 1 5 selects a directory by clicking on a directory name in input 352, enters a file name in 
input and then clicks on the save button 356. After saving the file, Executable 50 determines 
that client computer 6 does not have a vaUd hcense for the file 61 within storage 44 and 
displays the dialog 370, prompting the user 15 to select whether download a license firom the 
server 8. The user 15 opts to download a license by clicking on the "go online" button 372. 

10 Referring to FIG. 6, Executable 50 causes the browser 50 to display a web page 390 

while Executable 50 is generating (212 FIG. 3) and sending (214 FIG. 3) a put/get request to 
the server to inform the server that the user 1 5 would like to download a license. The web 
page 390 contains information 392 informing the user 15 that the Executable 50 is 
communicating with the server 8. 

15 Referring to FIG. 7, the FDF file sent (216 FIG. 3) by the web server includes 

instructions, which are executed by Executable 50 to cause the web browser to display a web 
page 410. The web page informs the user 15 that server 8 is requesting the computer ID 46 
and the storage ID 48 of the client computer 6, The user 15 opts to submit the IDs 46, 48 by 
clicking on the submit button 420. 

20 Referring to FIG. 8, after the extraction module 76 has extracted the ID information 

firom the cUent computer 6, the server 8 sends the web page 430 to the web browser 50, 
which displays the web page 430. The user 1 5 enters his name into a "name" input 432 and 
his electronic mail address into an "e-mail" input 434. The user 15 also selects to send the 
extracted Machine ID 46 and storage ID 48. To order the license 63, the user 1 5 submits the 

25 information on the page 430 by clicking on the "order" button 436. 

Referring to FIG. 9, after ordering the page, the web browser 50 displays the web 
page 440 that includes a paragraph 442 thanking the user 15 for downloading the license. 
The web page also includes a paragraph 434 informing the user 1 5 that the server 8 is 
sending a license to the cHent computer 6. 

30 Referring to FIG. 10, Executable 50 displays the contents PDF file when the 

downloading of the license is completed. 
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A number of embodiments of the invention have been described. Nevertheless, it will 
be understood that various modifications may be made without departing from the spirit and 
scope of the invention. For example, the method of commxmicating with an executable is not 
limited to Acrobat and may be applied to any executable or web browser plugin. Similarly, a 
5 different document format or mime-type from the FDF format may be used to represent the 
files. The files may contain any one or any combination of instructions, files or licenses. 
The files contained within the document format need not be a PDF document. It may, 
instead, be a computer program. For example, the FDF file may contain a newer version of 
Helper executable 50 and the system 2 (FIG. 1) may allow the server 8 to update the version 
10 of Helper executable 50 by downloading the newer version in an FDF file that also contains 
instructions on how to install Acrobat 50. 

The files need not be related to a computer executable by a mime-type association. 
They could, instead, be related to a computer executable by some other association, such as 
an operating system association. Similarly, the information extracted from the client 
1 5 computer need not be a machine ID or a storage ED. It could be any information about the 
environment or habitat of the computer. For example, the information may be a public key 
stored within the storage subsystem, a usemame/password pair, a date or a time. 

Accordingly, other embodiments are within the scope of the following claims. 
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WHAT IS CLAIMED IS: 

1 apparatus comprising: 

2 a computer executable for processing a file of a first file type, comprising: 

3 a first module that determines whether the file includes a first content 

4 type, the first module performing a first function if the file includes the first 

5 content type, and 

6 a second module that determines whether the file includes a second 

7 content type, the second module performing a second fimction different fi-om the 

8 first fimction if the file includes the second content type; and 

9 a HTTP client that receives files of the first type and a second type from a 

1 0 network, the HTTP client causing the computer executable to process files of the 

1 1 first type. 

1 2. The apparatus of claim 1 , wherein the first content type includes a set of 

2 instructions and the first module executes the instructions. 

1 3. The apparatus of claim 2, wherein the apparatus is associated with a computer 

2 processor and the computer executable fiirther comprises an extraction module, 

3 the instructions causing the extraction module to extract information from the 

4 computer. 

1 4. The apparatus of claim 3, wherein the computer executable fiirther comprises a 

2 third module for transmitting the extracted information by generating a HTTP 

3 request containing the information and sending the HTTP request over the 

4 network, 

1 5. The apparatus of claim 3, wherein the extracted information includes habitat 

2 information. 

1 6. The apparatus of claim 5 wherein the habitat information includes at least one of a 

2 machine ID, a storage ID, an Ethemet address, and a processor ID. 
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1 7. The apparatus of claim 2, wherein the instructions cause the first module to install 

2 computer software on a computer associated with the apparatus. 

1 8. The apparatus of claim 7, wherein the computer software is an updated version of 

2 the computer executable for processing a file. 

1 9. The apparatus of claim 1, wherein at least one of the first and second functions 

2 includes displaying at least a portion of the information contained within the file. 

1 10. The apparatus of claim 1, wherein at least one of the first and second fimctions 

2 includes uncompressing at least a portion of the information contained within the 

3 file. 

1 11. The apparatus of claim 1, wherein at least one of the first and second fimctions 

2 includes storing at least a portion of the information contained within the file. 

1 12. The apparatus of claim 3, wherein the computer executable fiirther comprising an 

2 HTTP module that generates a hypertext transfer protocol method for sending the 

3 extracted information over a network. 

1 13. The apparatus of claim 12 wherein the method is either a PUT or a GET method. 

1 method for processing a file comprising: 

2 receiving the file and information about the type of the file; 

3 determining a computer executable associated with the file based on the 

4 information about the type of the file; and 

5 causing the computer executable to process the file, with processing fiirther 

6 comprising: 

7 determining whether the file includes a first content type, the computer 

8 executable performing a first fimction if the file includes the first content type; 

9 and 

10 determining whether the file includes a second content type, the 

1 1 computer executable performing a second function different from the first 

12 function if the file includes the second content type. 
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1 15. The method of claim 14, further comprising: 

2 generating a HTTP request containing information and sending the 

3 information by sending the HTTP request over a network. 

1 16. The method of claim 14, wherein the first content type includes a set of 

2 instructions and the first fimction executes the instructions. 

1 17. The method of claim 16, wherein the method is associated with a computer, the 

2 instructions causing the extraction modxile to extract information from the 

3 computer. 

1 18. The method of claim 17, wherein the extracted information includes habitat 

2 information. 

1 1 9. The method of claim 1 8, wherein the habitat information includes at least one of a 

2 machine ID, a storage ID, and an Ethemet address. 

1 20. The method of claim 1 6, wherein the instructions cause the computer executable 

2 to install computer software on the computer. 

1 21 . The method of claim 20, wherein the computer software is an updated version of 

2 the computer executable. 

1 22. The method of claim 14, wherein at least one of the first and second fimctions 

2 includes displaying at least a portion of the information contained within the file. 

1 23. The method of claim 14, wherein at least one of the first and second fimctions 

2 includes uncompressing at least a portion of the information contained within the 

3 file. 

1 24. The method of claim 14, wherein at least one of the first and second fimctions 

2 includes storing at least a portion of the information contained within the file. 

1 25. The method of claim 1 5 wherein the method is either a PUT or a GET method. 
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26. The method of claim 14, wherein the file contains both the first content type and 
the second content type, the computer executable processing the file to perform 
both the first and the second fimction. 
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ABSTRACT 

An apparatus includes a computer executable for processing a file of a first file type, 
and a Hypertext Transfer Protocol ("HTTP") client that receives files of the first type and a 
second type firom a network. The HTTP client causes the computer executable to process 
5 files of the first type. The computer executable includes a first module that determines 

whether the file includes a first content type and performs a first function if the file includes 
the first content type. The computer executable also includes a second module that 
determines whether the file includes a second content type and performs a second function 
different fi:om the first function if the file includes the second content type, 

10 20084808 
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COMBINED DECLARATION AND POWER OF ATTORNEY 



As a below-named Inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated next to my name. 

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, 
first and joint inventor (if plural names are listed below) of the subject matter that is claimed and for which a 
patent is sought on the Invention entitled: 

COMMUNICATING DATA USING AN HTTP CLIENT 

the specification of which: 

\X] is attached hereto. 

[ ] was filed on . 

[ ] under Application No. . 

pq with Express Mail No. EL224703344US (Application Number not yet known). 

[ ] was described and claimed in PCT Intemationai Application No. . 

I hereby state that i have reviewed and understand the contents of the above-identified 
specification, including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose infomiation that is material to the examination of this application 
in accordance with Title 37, code of Federal Regulations, Section 1.56(a). 

! hereby appoint the following attorneys and/or agents to prosecute this application and to transact 
all business in the Patent and Trademark Office connected therewith, and direct that all con-espondence be 
addressed to that Customer Number: 

Customer Number 021876 

Address all telephone calls to Hans Troesch, Reg, No. 36,950 at telephone number (650) 322- 

5070. 



[X] For Assigned Inventions: I understand that the purpose of making this appointment is to pennit 
prosecution of patent applications for the above-Identified invention for the benefit of my assignee, and that 
this appointment does not create an attorney-client relationship between me and these appointees. 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on Information and belief are believed to be true; and further that these statements were 
made with the knowledge that willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false 
statements may jeopardize the validity of the application or any patent issued thereon. 
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James D. Pravetz 



Inventor's signature 
Date: 

Residence: 
Citizen of: 

Post Office Address: 



Full name of inventor: 



Inventor's signature 
Date: 

Residence: 
Citizen of: 

Post Office Address: 



270 Hazelton Avenue, Sunnyvale, OA 94086-4306, USA 
USA 

270 Hazelton Avenue, Sunnyvale, OA 94086-4306, USA 



Richard L. Sites 



145 Campo Bello Ln, Menio Park, OA 94025, USA 
USA 

145 Campo Bello Ln, MenIo Park, CA 94025, USA 
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